package cn.zqy.demo2.day09.InputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.Arrays;
/**
 *  字节输入流一次读取多个字节的方法:
 *         int read(byte[] b) 从输入流中读取一定数量的字节，并将其存储在缓冲区数组 b 中。
 *     明确两件事情:
 *         1.方法的参数byte[]的作用?
 *             起到缓冲作用,存储每次读取到的多个字节
 *             数组的长度一把定义为1024(1kb)或者1024的整数倍
 *         2.方法的返回值int是什么?
 *             每次读取的有效字节个数
 *
 *     String类的构造方法
 *         String(byte[] bytes) :把字节数组转换为字符串
 *         String(byte[] bytes, int offset, int length) 把字节数组的一部分转换为字符串 offset:数组的开始索引 length:转换的字节个数
 * */
public class Demo02FileInputStream {
    public static void main(String[] args) throws IOException {
        File fs = new File("src\\cn\\zqy\\demo2\\day09\\inputstream\\input\\demo02.txt");
        fs.createNewFile();

        //创建FileInputStream对象,构造方法中绑定要读取的数据源
        FileInputStream fis = new FileInputStream("src\\cn\\zqy\\demo2\\day09\\inputstream\\input\\demo02.txt");

        //int  read(byte[] b) 从输入流中读取一定数量的字节，并将其存储在缓冲区数组中。
        /*byte[] bytes = new byte[2];
        int len = fis.read(bytes);
        System.out.println(len);  // 2
        System.out.println(Arrays.toString(bytes));  // [65, 66]
        System.out.println(new String(bytes));  // AB

        len = fis.read(bytes);
        System.out.println(len);  // 2
        System.out.println(new String(bytes));  // CD

        len = fis.read(bytes);
        System.out.println(len);  // 1
        System.out.println(new String(bytes));  // ED


        len = fis.read(bytes);
        System.out.println(len);  // -1
        System.out.println(new String(bytes));  // ED*/


        /*
            发现以上读取时一个重复的过程,可以使用循环优化
            不知道文件中有多少字节,所以使用while循环
            while循环结束的条件,读取到-1结束
         */

        int len = 0;
        byte[] b = new byte[2];
        while ((len = fis.read(b)) != -1) {
            System.out.println(new String(b, 0, len));  // AB  CD  E
        }

        // 释放资源
        fis.close();
    }
}
